1557C - Moamen and XOR - CodeForces Solution


bitmasks combinatorics dp math matrices *1700

Please click on ads to support us..

C++ Code:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll mod=1e9+7;
int T;
ll n,k;
ll ksm(ll x,ll y){
	if(y==0) return 1; 
	ll tmp=1;
	while(y){
		if(y&1) tmp=(tmp*x)%mod;
		x=(x*x)%mod;
		y/=2; 
	}
	return tmp%mod;
}
int main(){
	scanf("%d",&T);
	while(T--){
		scanf("%lld%lld",&n,&k);
		ll ans=0,p=1;
		for(ll i=1;i<=k;++i){
			if(n%2==0){
				if(k==i) ans+=p;
				else ans=ans+(p*(ksm(ksm(2,k-i),n)))%mod;
				ans=ans%mod;
			}
			ll tmp;
			if(n%2) tmp=(ksm(2,n-1)+1)%mod;
			else tmp=(ksm(2,n-1)-1)%mod;
			p=(p*tmp)%mod;
		}
		ans=(ans+p)%mod;
		printf("%lld\n",ans);
	}
	return 0;
}


Comments

Submit
0 Comments
More Questions

1469A - Regular Bracket Sequence
919C - Seat Arrangements
1634A - Reverse and Concatenate
1619C - Wrong Addition
1437A - Marketing Scheme
1473B - String LCM
1374A - Required Remainder
1265E - Beautiful Mirrors
1296A - Array with Odd Sum
1385A - Three Pairwise Maximums
911A - Nearest Minimums
102B - Sum of Digits
707A - Brain's Photos
1331B - Limericks
305B - Continued Fractions
1165B - Polycarp Training
1646C - Factorials and Powers of Two
596A - Wilbur and Swimming Pool
1462B - Last Year's Substring
1608B - Build the Permutation
1505A - Is it rated - 2
169A - Chores
765A - Neverending competitions
1303A - Erasing Zeroes
1005B - Delete from the Left
94A - Restoring Password
1529B - Sifid and Strange Subsequences
1455C - Ping-pong
1644C - Increase Subarray Sums
1433A - Boring Apartments